package top.scsoul.voes.examination.service;

import com.github.pagehelper.PageInfo;
import org.springframework.web.multipart.MultipartFile;
import top.scsoul.voes.examination.entity.QuestionBank;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;
import java.util.Map;

/**
 * (QuestionBank)表服务接口
 *
 * @author guolei
 * @since 2021-07-23 13:10:43
 */
public interface QuestionBankService {

    /**
     * 通过ID查询单条数据
     *
     * @param id     主键
     * @param answer 需要答案？
     * @return 实例对象
     */
    QuestionBank queryById(Integer id, boolean answer);

    QuestionBank queryById(Integer id);


    /**
     * 查询多条数据
     *
     * @param offset 查询起始位置
     * @param limit  查询条数
     * @return 对象列表
     */
    List<QuestionBank> queryAllByLimit(int offset, int limit);

    /**
     * 查询多条数据
     *
     * @return 对象列表
     */
    PageInfo<QuestionBank> queryAll(QuestionBank questionBank, int currentPage, int pageSize);

    /**
     * 新增数据
     *
     * @param questionBank 实例对象
     * @return 实例对象
     */
    QuestionBank insert(QuestionBank questionBank);

    /**
     * 修改数据
     *
     * @param questionBank 实例对象
     * @return 实例对象
     */
    QuestionBank update(QuestionBank questionBank);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Integer id);

    boolean deleteByIds(List<Integer> ids);

    Map<String, Long> searchCount(String keyWord);

    void importExcel(HttpServletResponse response) throws IOException;

    Integer uploadExcel(MultipartFile file) throws IOException;

    void getExcelModel(HttpServletResponse response) throws IOException;

}